<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <meta http-equiv="X-UA-Compatible" content="ie=edge">
  <title>component 父子组件关系(父组件内嵌套子组件)</title>
  <script src="../assets/js/vue.js"></script>
</head>
<body>
  <h1>component 父子组件关系</h1>
  <hr>
  <div id="app">
    <!-- 这里panda定义的自组件不能直接写在panda标签中，应该写在panda的template定义的标签里面，这样会生效 -->
    <panda here='china' />
  </div>
  <script>
    var cityObj = {
      template: `<h5 style="color: green">子组件{{ myName }}</h5>`,
      props: ['myName']
    }
    var componentObj = {
      template: `<h3>
        局部组件{{ here }}
        <city my-name='cs' />
      </h3>`,
      props: ['here'],
      components: {
        city: cityObj, // 这里声明的是自组件，格式和父组件的一样，只是在父组件的选项中多了一个components，进行重新设置即可
      }
    }
    // 这里的cityObj会有顺序问题，写的时候注意，否则会说city组件没有注册
    var cityObj = {
      template: `<h5 style="color: green">子组件</h5>`,
    }
    var vue = new Vue({
      el: '#app',
      components: {
        panda: componentObj,
      }
    })
  </script>
</body>
</html>